// 导航守卫
// 引入路由
import router from './router/index'
// 引入vuex
import store from './store'

router.beforeEach(async(to, from, next) => {
  // 如果已登入
  if (store.getters.token) {
    if (to.path === '/login') {
      // 就跳转到首页
      next('/')
    } else {
      // 这里是已经登录进入普通的后台页面
    // 放行之前要确保数据的存在, 如果没有就发请求
      if (!store.state.user.userInfo.username) {
        await store.dispatch('user/getUserInfo')
      }
      next()
    }
  } else {
    // 未登入,可以访问的页面
    const whiteList = ['/login', '/404']
    // 如果是去的白名单就放行
    if (whiteList.indexOf(to.path) !== -1) {
      next()
    } else {
      // 否则跳转到登入页面
      next('/login')
    }
  }
})
